regs->eax = info->func(info->data);
v->arch.schedule_tail = info->saved_schedule_tail;
+ v->cpu_affinity = info->saved_affinity;
v->arch.continue_info = NULL;
xfree(info);
+ d->time_offset_seconds;
}
+/* "cmos_utc_offset" is the difference between UTC time and CMOS time. */
+static long cmos_utc_offset; /* in seconds */
+
int time_suspend(void)
{
+ cmos_utc_offset = (wc_sec + (wc_nsec + NOW()) / 1000000000ULL)
+ - get_cmos_time();
+
/* Better to cancel calibration timer for accuracy. */
kill_timer(&this_cpu(cpu_time).calibration_timer);
set_time_scale(&this_cpu(cpu_time).tsc_scale, tmp);
resume_platform_timer();
- do_settime(get_cmos_time(), 0, read_platform_stime());
+
+ do_settime(get_cmos_time() + cmos_utc_offset, 0, read_platform_stime());
init_percpu_time();